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(57) Abstract: The present invention is embodied in a video flash- 
light method. This method creates virtual images of a scene using 
a dynamically updated three-dimensional model of the scene and 
at least one video sequence of images. An estimate of the camera 
pose is generated by comparing a present image to the three-di- 
mensional model. Next, relevant features of the model are selected 
based on the estimated pose. The relevant features are then virtu- 
ally projected onto the estimated pose and matched to features of 
the image. Matching errors are measured between the relevant fea- 
tures of the virtual projection and the features of the image. The 
estimated pose is then updated to reduce these matching errors. 
The model is also refined with updated information from the im- 
age. Meanwhile, a viewpoint for a virtual image is selected. The 
virtual image is then created by projecting the dynamically updated 
three-dimensional model onto the selected virtual viewpoint 
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A METHOD OF POSE ESTIMATION AND MODEL REFINEMENT FOR VIDEO 
REPRESENTATION OF A THREE DIMENSIONAL SCENE 
[0001] This application claims the benefit of the filing date of the Provisional 

application 60/187,557 filed March 7, 2000, the contents of which are incorporated herein 
by reference. 

[0002] The present invention is directed toward the domain of image processing, 

in particular toward the creation and manipulation of three dimensional scene models and 
virtual images of the scene seen from arbitrary viewpoints. 

BACKGROUND OF THE INVENTION 
[0003] Tremendous progress in the computational capability of integrated 

electronics and increasing sophistication in the algorithms for smart video processing has 
lead to special effects wizardry, which creates spectacular images and otherworldly 
fantasies. It is also bringing advanced video and image analysis applications into the 
mainstream. Furthermore, video cameras are becoming ubiquitous. Video CMOS 
cameras costing only a few dollars are already being built into cars, portable computers 
and even toys. Cameras are being embedded everywhere, in all variety of products and 
systems just as microprocessors are. 

[0004] At the same time, increasing bandwidth on the Internet and other delivery 

media has brought widespread use of camera systems to provide live video imagery of 
remote locations. In order to provide coverage of live video imagery of a remote site, it 
is often desirable to create representations of the environment to allow realistic viewer 
movement through the site. The environment consists of static parts (building, roads, 
trees, etc.) and dynamic parts (people, cars, etc.). The geometry of the static parts of the 
environment can be modeled offline using a number of well-established techniques. None 
of these techniques has yet provided a completely automatic solution for modeling 
relatively complex environments, but because the static parts do not change, offline, non- 
real time, interactive modeling may suffice for some applications. A number of 
commercially available systems (GLMX, PhotoModeler, etc.) provide interactive tools for 
modeling environments and objects. 

[0005] For arbitrary 3D scenes, various modeling approaches have been proposed, 

such as image-based rendering, light fields, volume rendering, and superquadrics plus 
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shape variations. For general modeling of static scenes, site models are known to provide 
a viable option. In the traditional graphics pipeline based rendering, scene and object 
models stored as polygonal models and scene graphs are rendered using Z-buffering and 
texture mapping. The complexity of such rendering is dependent on the complexity of the 
scene. Standard graphics pipeline hardware has been optimized for high performance 
rendering. 

[0006] However, current site models do not include appearance representations 

that capture the changing appearance of the scene. Also these methods generally seek to 
create a high quality model from scratch, which in practice necessitates constrained 
motion, instrumented cameras, or interactive techniques to obtain accurate pose and 
structure. The pose of the camera defines both its position and orientation. The dynamic 
components of a scene cannot, by definition, be modeled once and for all. Even for the 
static parts, the appearance of the scene changes due to varying illumination and shadows, 
and through modifications to the environment. For maintaining up-to-date appearance of 
the static parts of the scene, videos provide a cost-effective and viable source of current 
information about the scene, but unless the cameras are fixed, the issue of obtaining 
accurate pose information remains. 

[0007] Between a pair of real cameras, virtual viewpoints may be created by 

tweening images from the two nearest cameras. Optical flow methods are commonly used 
by themselves to create tweened images. Unfortunately, the use of only traditional optical 
flow methods can lead to several problems in creating a tweened image. Particularly 
difficult are the resolution of large motions, especially of thin structures, for example the 
swing of a baseball bat; and occlusion/deocclusions, for example between a person's 
hands and body .The body of work on structure from motion may be pertinent to 3D-scene 
modeling. Purely image-driven methods, however, tend to drift away from metric 
accuracy over extended image sequences, because there is no constraint to tie down the 
estimated structure to the coordinate system of the real world. That constraint must come 
from physical measurements like GPS, or surveyed landmarks, or from a prior scene 
model with shape and/or texture information. The problem of loss of metric accuracy is 
particularly acute for analysis and control of a remote scene in which use of such 
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constraint indicia is not practical, for example to control a remote vehicle on Mars or 
underground. 

SUMMARY OF THE INVENTION 

[0009] The present invention is embodied in a method of accurately estimating a 

pose of a camera within a scene using a three dimensional model of the scene. The 
exemplary method begins by generating an initial estimate of the camera pose. Next, a set 
of relevant features of the three-dimensional model based on the estimate of the pose is 
selected. A virtual projection of this set of relevant features as seen from the estimated 
pose is then created. The virtual projection of the set of relevant features is matched to 
features of the received image and matching errors between the features of the image and 
the features of the projection are measured. The estimate of the pose is then updated to 
reduce the matching errors. 

[0010] A second embodiment of the present invention is method of refining a three 

dimensional model of a scene using an image of the scene taken by a camera, which may 
have an unknown pose. First the image is compared to the three dimensional model of the 
scene to generate an estimate of the camera pose. The three dimensional model of the 
scene is then updated based on data from the image and the estimated pose. 
[0011] Another embodiment of the present invention is a method of accurately 

estimating a position of remote vehicle using a three dimensional model and an image 
from a camera having a known orientation relative to the remote vehicle. The image is 
compared to the three dimensional model of the scene to generate an initial estimate of the 
pose. A set of relevant features of the three dimensional model are selected and matched 
to features of the image. Matching errors are then measured and used to update the 
estimate of the pose. The position of the remote vehicle is determined using the estimated 
pose and the orientation of the camera. The three dimensional model may then be updated 
based on data from the image and the estimate of the pose. 

[0012] Yet another embodiment of the present invention is a method of refining a 

three dimensional model of a scene containing an object using a plurality of images of the 
scene. First, a first image and a second image are compared to the three dimensional 
model of the scene to generate first and second pose estimates. Then, the first image and 
the second image are compared to one another to generate relative pose constraints. The 
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first pose and the second pose are updated based on these relative pose constraints. Two 
sets of relevant features of the three-dimensional model corresponding to the first pose 
and the second pose are selected. These sets of relevant features are then matched to 
features in the first and second images, and two sets of matching errors are measured. 
The position estimate of the object within the three-dimensional model is then updated to 
reduce the two sets of matching errors. 

[0013] The present invention is also embodied in a method of creating a textured 

three-dimensional model of a scene using a plurality of images of the scene. First a 
polyhedral model the scene including a plurality of polygonal surfaces is created. Each 
polygonal surface in the polyhedral model is larger than a predetermined size. One 
polygonal surface is then separated into a plurality of portions. For a selected portion, a 
subset of images containing that portion of the polygonal surface is identified. The 
corresponding section of the selected image is then projected onto the selected portion of 
the polygonal surface in the textured three-dimensional model as a local color map. 
[0014] The present invention is also embodied in a video flashlight method of 

creating a dynamic sequence of virtual images of a scene using a dynamically updated 
three dimensional model of the scene. The three dimensional model is updated using a 
video sequence of images of the scene as described with regard to the second embodiment 
of the present invention. Meanwhile a viewpoint of a virtual image is selected. The 
virtual image is then created by projecting the dynamic three-dimensional model onto the 
virtual viewpoint. 

BRIEF DESCRIPTION OF THE FIGURES 
[0015] Figure 1 is a top plan drawing of several cameras viewing a scene. 

[0016] Figure 2 is a perspective drawing of a polyhedral model of the scene in 

Figure 1. 

[0017] Figure 3 is a drawing illustrating selection of relevant features from the 

polyhedral model of Figure 2. 

[0018] Figure 4 is a flowchart illustrating an embodiment of the present invention 

to accurately estimate the pose of an image of a scene using a three dimensional model of 
the scene. 
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[0019] Figure 5 is a flowchart illustrating an embodiment of the present invention 

to update a three dimensional model of a scene using an image of the scene with an 
unknown pose. 

[0020] Figure 6 is a perspective drawing illustrating the use of epipolar geometry 

to determine the relative pose of two images. 

[0021] Figure 7 is a flowchart illustrating an embodiment of the present invention 

to update a three dimensional model of a scene using a pair of images of the scene with 
unknown poses. 

[0022] Figure 8 is a top plan drawing illustrating a remote vehicle with a mounted 

camera viewing the scene from Figure 1. 

[0023] Figure 9 is a flowchart illustrating an embodiment of the present invention 

to accurately estimate the position of a remote vehicle within a scene using a three 
dimensional model of the scene and an image of the scene. 

[0024] Figure 10 is a perspective drawing of a surface from Figure 2 illustrating 

the separation of the surface into approximately equal sized portions used in an exemplary 
hybrid three dimensional model according to the present invention. 
[0025] Figure 1 1 is a flowchart illustrating an embodiment of the present invention 

to create a hybrid three-dimensional model of a scene. 

[0026] Figure 12 is a perspective drawing of a scene illustrating an exemplary 

video flashlight method of the present invention. 

[0027] Figure 13 is a flowchart illustrating an embodiment of the present invention 

to create virtual images of a scene and a dynamic three-dimensional model of the scene 
using a video flashlight method. 

DETAILED DESCRIPTION OF THE INVENTION 
[0028] The present invention embodies systems and methods for processing one or 

more video streams, for the purposes of progressively constructing and refining a 3D- 
scene model, geolocating objects, and enhanced visualization of dynamic scenes. One 
embodiment of the present invention is a progressive strategy to model construction and 
refinement, starting with a coarse model and incrementally refining it with information 



WO 01/67749 PCT/US01/07099 



derived from freely moving video cameras, thereby increasing the spatial fidelity and 
temporal currentness of the model. 

[0029] Figure 1 is a top plan drawing showing several cameras 108, which may be 

stationary or may be in motion. The cameras view an exemplary scene 100, containing 
three objects, cube 102, star prism 104, and cylinder 106. 

[0030] Figure 2 is a perspective drawing of an exemplary polyhedral model of 

scene 100 from Figure 1. All objects in this model are all represented as polyhedra 
composed of planar polygonal surfaces 200, even a curved object, such as cylinder 106. 
To accomplish such a polyhedral representation, the modeled representation of cylinder 
106 contains artificial edge boundaries 204. Also shown in Figure 2 are dotted lines 202, 
which represent edge boundaries that are hidden in the illustrated view of the model. 
While this model is shown as an image of a physical scene, it is contemplated that the 
model may be a mathematical representation of the scene, stored in a data file. 
[0031] A first exemplary embodiment of the present invention is a method of 

automatic pose estimation and registration of video to an existing polyhedral scene model, 
which may or may not have texture information suitable for registration. The method of 
this embodiment may be used to estimate camera pose with respect to textured or 
untextured models, by optimizing the fit between line segments projected from model to 
image and the gradients of image intensity. This method may be combined with 
interframe prediction to continuously track a video stream. 

[0032] Figure 4 is a flowchart illustrating this exemplary embodiment of the 

present invention. The method begins with a three dimensional model of the scene, 400, 
such as that shown in Figure 2. The first step, 402, is to generate an initial, rough 
estimate of the pose of an image by comparing the image to the three dimension model of 
the scene. Numerous methods may be used to obtain this initial estimate. In an interactive 
system, a user can set the pose for the first frame. Physical measurements from 
position/attitude sensors mounted on the camera platform may be another source. 
Alternatively, when processing a sequence of frames, the estimated pose of the previous 
frame may be used as the initial pose, or the pose can be predicted from the previous 
frame's estimated pose based on assumed motion. Interframe alignment may also be used 
to assist with prediction and with overcoming ambiguity. One method for dete rminin g an 



WO 01/67749 PCT/US01/07099 

-7- 



initial pose estimate may be to extract corresponding 2D feature points from a pair of 
successive images using an optical flow technique. In order to support large 
displacements, flow estimation may be initialized with the 2D projective motion field 
estimated by a global parametric motion algorithm. Methods for flow estimation of this 
type are described in U.S. Patent number 5,629,988, entitled "SYSTEM AND METHOD 
FOR ELECTRONIC IMAGE STABILIZATION". Next, each selected feature point is 
mapped into its corresponding 3D point in the world view by using the current estimated 
pose and the current shape model. The initial pose estimate is then determined from the 
set of 3D and 2D correspondences. This may be done, for example, using the Random 
Sample Consensus (RANSAC) method of robust least squares fitting. Even though the 
current pose and shape model may include significant errors, these errors should be 
reduced in the process of refining the image to model alignment. 
[0033] Next a set of relevant features is selected from the three dimensional model 

based on the estimate of the pose, step 404. The existing model may be considered a 
collection of untextured polygonal faces. Face edges in the model imply discontinuities in 
surface normal and/or material properties in the actual 3D scene, which generally induce 
brightness edges in an image. Although the subject invention is described in terms of 
brightness edges, it is contemplated that other types of edges may be used such as those 
defined by changes in color or texture on an appropriately colored and/or textured model. 
Because they are relatively easy to identify, an exemplary alignment method selects 3D 
line segments from the model as relevant features. 

[0034] Figure 3 is a drawing illustrating selection of relevant features 302 from the 

polyhedral model of Figure 2. Figure 3 is drawn to have the same pose as that used for 
the perspective drawing of Figure 2. Given an initial pose estimate, occluded fragments 
of model features, dotted lines 202 in Figure 2, may be deleted by known methods, such 
as a Z-buffer hidden line removal process. 

[0035] Because many models of objects, such as buildings, may be constructed for 

various applications besides pose estimation (e.g. architecture), many model edges will 
not induce brightness edges in the image. Even after occluded edge fragments are 
suppressed, a model may contain clutter such as edges occluded by unmodeled objects, 
edges of structures that are semantically but not geometrically significant, edges between 
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faces meeting at a shallow angle. Pose estimation may be adversely affected if too much 
model clutter happens to fall close to image edges. Therefore, it is important to cull the 
edges of the polyhedral model to keep those most likely to induce brightness edges. 
[0036] Additionally, multiple local minima in pose estimation may be caused by 

closely spaced edges in either the model or the image even if they correspond to 
brightness edges in the image. Therefore, once the possible relevant features of the model 
have been identified, a projection of these features as they appear in the estimated pose is 
created, step 406 in Figure 4, and projected model features are culled out if any similarly 
oriented projected model edge lies near it. Projected model features may also be culled if 
image texture analysis reveals the presence of multiple image edges within a 
predetermined distance. This culling may be dynamically adapted to the current level of 
uncertainty, so that as pose becomes better known, more edges can be included for 
increased pose estimation accuracy. 

[0037] Application-dependent heuristics for this culling may be applied, for 

example, keeping only model edges common to exactly two faces, keeping edges only at 
large dihedral angles, ignoring edges which are too close together, and ignoring edges 
near and on the ground (terrain faces may be annotated in the given model). In Figure 3 
the dotted lines 300 represent features which have been ignored in this exemplary pose as 
too close to other lines. Also missing are the artificial edge boundaries 204 from the 
model shown in Figure 2, as the their dihedral angles have been determined to be too 
small. 

[0038] While the pose, and hence occlusions, may change during the optimization 

process, it may suffice to cull model edges once when initializing the optimization and 
afterwards only if the pose changes significantly. This determination, based on the 
change in the estimated pose in the exemplary method of Figure 4, is shown as step 418. 
If the pose of the camera has changed by more than a threshold amount since the features 
were selected from the model, step 418 jumps to step 404 to select a new set of features. 
The process of pose refinement desirably leads toward smaller changes in the estimated 
pose. Therefore, often the estimate of pose will quickly become approximately correct. 
In this instance, step 418 branches to step 406 and same set of relevant features will be 
used throughout the remaining pose refinement. 
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[0039] It is noted that, though the embodiments of the present invention mostly 

disclose the measurement and reduction of matching errors, one of skill in the art may 
easily practice the present invention by, instead, measuring and increasing matching 
scores without substantially altering the invention. 

[0040] Next, the virtual projection of the relevant features is matched to brightness 

features in the image, step 408. Additionally, color and/or texture edges may be used to 
generate image features, not just brightness edges. Matching errors are generated to 
indicate the goodness of the fit, step 410. The estimated pose is then updated based on 
these matching errors, step 412. The matching error calculation may be accomplished by 
many methods, including a number of image processing methods used for image warping 
and mosaic construction. 

[0041] In the case of an already-textured model, constructed from a previous set of 

images, the matching of image intensity patterns in the image to the textured model may 
be accomplished following the teachings of U.S. Patent Application number 09/075462, 
entitled "METHOD AND APPARATUS FOR PERFORMING GEO-SPATIAL 
REGISTRATION" and U.S. Provisional Application number 60/141460, entitled "GEO- 
SPATIAL REGISTRATION USING EUCLIDEAN REPRESENTATION". 
[0042] One difficulty that may arise is that an image may have brightness edges 

that are close together, causing local minima in the objective function. Also, if the given 
polyhedral model does not agree with veridical scene structure, no pose can 
simultaneously align all edge features well. Projected model features may get stuck at the 
wrong image edge, preventing progress towards the correct pose. 
[0043] Several approaches to mitigate this problem exist. One exemplary method 

is to use any of a number of discrete search schemes. Perturbing the pose estimate, either 
at the initial estimate, step 402, or during refinement, step 412, is one method that may 
increase the likelihood of finding the global minimum. These perturbations in pose 
estimate may be generated by explicitly perturbing the pose parameters. Alternatively, 
they may be generated in a data-driven fashion, as in RANSAC, wherein pose hypotheses 
are estimated from many randomly chosen subsets of the model features. 
[0044] For video sequences, interframe registration may be used to yield 

constraints on relative poses of neighboring frames, which, in turn, may allow poses of a 
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collection of frames to be determined unambiguously. If a set of nearby frames 
collectively views a larger set of edges than any single frame, simultaneously exploiting 
image-to-model constraints in multiple frames may help to disambiguate pose. An 
exemplary embodiment of the present invention aligns the three dimensional model to a 
mosaic, virtual wide-angle image, from a virtual rigid rig of cameras. Suppose that a 
pose estimate has been predicted for one frame, but that this pose estimate is ambiguous 
due to a paucity of relevant model edges. For each of the remaining frames, interframe 
prediction may be used to obtain pose estimates. These pose estimates may then be 
treated as a virtual rigid rig of cameras. The total image-to-model error of the mosaic, 
virtual wide-angle image, created from these frames is then minimized. This method is 
particularly useful for scenes in which the features are relatively static. 
[0045] Mismatched features may also occur because the attributes being measured 

are not sufficiently discriminating. For example, a projected model feature may be 
matched equally well to an image edge of equal length, an image edge of longer length, or 
a series of short image edges. Many different methods for matching image features tuned 
to scale and orientation are known in the art. One method that may be used is pyramid 
processing. Both the image and the model may be processed into a pyramid of resolution 
levels. As the estimated pose becomes more accurate (i.e. the matching errors decrease), 
the resolution level, and number of features retained, may be increased. 
[0046] The matching errors may also be optimized with respect to the estimated 

pose via steepest descent. The natural representation of an infinitesimal change in the 
pose parameters as a translation and a cross product for small rotation, however, 
unweighted steepest descent tends to work slowly when the energy surface is highly 
anisotropic, and may get stuck in local minima. To solve this problem, the current pose 
estimate may be iteratively incremented by moving in the gradient direction in the space 
of an orthogonalized incremental pose parameter. In that space, a unit step in any 
direction causes the RMS change in line segment points of image features to be 1 pixel. 
[0047] One of the properties that may be desirable for the matching errors is a 

degree of robustness against outliers. Desirably this robustness includes both poorly 
fitting lines and model clutter, i.e. a spurious model feature that has no true matching 
image feature. If the projected feature lies far from any image feature, it contributes little 
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to the calculation of the gradient of estimated pose. To reduce the chance that a projected 
model line segment, whether an artifact of model clutter or a valid feature, would be 
attracted to a falsely matching image feature, dissimilarly oriented model and image edges 
may be ignored by using an oriented energy image tuned to the angle of the model line. 
[0048] Many different methods for generating a measure of local edge strength 

within an image tuned to scale and orientation are known. In an embodiment of the 
present invention, an oriented energy image including the oriented energy at a selected 
angle may be computed as follows. The source image is differentiated in the selected 
direction and smoothed in a perpendicular direction. The magnitude of the latter is 
smoothed in the selected direction. This method responds to both step edges and 
impulses. For computational efficiency, the orientation may be quantized to multiples of 
45° and scaled to powers of 2, as in a pyramid. 

[0049] Unfortunately, the robustness of this method may mean that, if the error in 

initial estimate of pose causes many model line segments to be projected far from their 
corresponding image features, the steepest descent may not move towards the true pose. 
An exemplary method to increase the capture range and speed convergence is to vary the 
scale of the energy image from coarse to fine resolution during the optimization process. 
The scale may desirably be tuned for each model line, commensurate with the expected 
amount of uncertainty in the location of predicted feature with respect to the actual 
corresponding image edge. 

[0050] It has been found that the capture range of coarse-to-fine pose estimation 

may be reasonably large for low complexity images, and limited only by the presence of 
multiple local minima in matching errors when the image has lots of edges. Thus, it may 
be desirable to exploit interframe constraints to ensure stable tracking over a sequence, 
such as by using prediction to initialize estimated pose in the correct mini m u m basin, or 
by multiframe alignment. Intelligent selection of a subset of model features is also 
critical. 

[0051] Also, the orientation tuning may be very broad in the oriented energy 

pyramid described above. The solution may be to add more discriminating feature 
attributes to the representation. The measure of the matching errors may be improved, 
for example, by using sharper orientation tuning. 
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[0052] Alternatively, in an outdoor site modeling application, the camera may only 

see a small part of the model at a time. Thus, there may be individual images that contain 
little texture or few model edges, so that matching features may be difficult and the pose 
may be undtermined. One method to overcome this difficulty is to combine several 
images to form a mosaic that is warped to the coordinate system of the current image. 
This composite image may be used in the algorithm, in place of the individual image, to 
determine the pose of the camera at the position of the current image. 
[0053] The process of pose refinement shown in steps 406, 408, 410, and 412 may 

be repeated until a set number of iterations have occurred, step 414, or until the matching 
errors fall below a set criteria, step 416 (alternatively, the matching score, if used, may 
exceed a predetermined level). 

[0054] Figure 5 is a flowchart illustrating an embodiment of the present invention 

to update a three dimensional model of a scene using an image of the scene with an 
unknown pose. This method begins with several steps that are similar to those described 
above with regard to Figure 4. As in the exemplary embodiments described with regard 
to Figure 4, the embodiment illustrating in Figure 5 begins with a three dimensional 
model of the scene, 500. This starting model may be very rudimentary and limited in its 
scope. As images are aligned and information from these images used to update the 
model, the detail and range of the model may both be increased. 

[0055] Still following the outline of Figure 4, the image is compared to the three 

dimensional model of the scene to generate an initial estimate of the pose, step 502. A set 
of relevant features are selected from the three dimensional model based on this pose 
estimate, step 504. The relevant features of the model are then projected and matched to 
features in the image to generate matching errors, step 506. Next, the estimated pose is 
updated based on the matching errors, step 508. Once again as previously described, the 
pose refinement process, shown in Figure 5 as steps 504, 506, and 508, may be repeated 
until a set number of iterations have occurred, step 510, or until the matching errors fall 
below a set criteria, step 512 (alternatively, if an embodiment employing a matching score 
is used, step 512 may query if the matching score exceeds a predetermined level). Step 
514 determines whether the pose estimate indicates that the pose of the camera has 
changed so much from the initial pose in which the current relevant features were selected 
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that it may be desirable to reselect a new set of relevant model features to be used for 
continued pose refinement. 

[0056] Once the pose estimate is completed, as evidenced by a 'yes' answer to the 

query of either step 510 or step 512, the data from the image is used to update the three 
dimensional model, step 516.. This update may include: the refinement of object 
placement within the scene; the additions of textural or fine structural detail to surfaces of 
objects; temporal updating of dynamic processes, such as changing illumination, or 
objects in motion; and the spatial extension of the scene being modeled. A number of 
methods to project image data onto a corresponding three dimensional model, such as a 
simple ray tracing method, are known in the art and may be used in step 516. For many 
of these methods it is desirable to use two, or more, images simultaneously, particularly 
to assist with refining object placement and identifying objects in motion. Figure 6 is a 
perspective drawing illustrating a plane in the scene, 600, and the poses of two images, 
602 and 604, of the scene, both of which include object 606. Significant work has been 
done using the epipolar geometry shown in Figure 6 for image processing and mosaic 
construction. In this Figure, the epipole is shown as the line O-O'. The epipolar 
geometry of a scene may also be used to place constraints on the relative pose of images 
602 and 604 even if the location of object 606 within the scene is not known. 
Additionally, plane plus parallax methods may be used to generate relative pose 
constraints between images. A detailed discussion of some of these methods is provided 
in U.S. Patent number 6,192,145, entitled "METHOD AND APPARATUS FOR 
THREE-DIMENSIONAL SCENE PROCESSING USING PARALLAX GEOMETRY 
OF PAIRS OF POINTS". 

[0058] Figure 7 is a flowchart illustrating another exemplary embodiment of the 

present invention. This exemplary method is similar to that previously described with 
regard to Figure 5, but uses multiple images of the scene with unknown poses to update a 
three dimensional model of a scene. Although the exemplary method shown in Figure 7 
only employs two images at a time, it is contemplated that three or more images may be 
simultaneously used in this embodiment. The images may be successive images from a 
moving source, or they may be concurrently generated images from multiple sources. 
The parallel paths in Figure 7, such as steps 702 and 704, represent parallel processes, 
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which may occurs as multi-threaded tasks within the image processing hardware of the 
present invention. It may be desirable for these tasks to be performed concurrently by 
parallel processors to increase processing speed. 

[0059] As in previously described embodiments of the present invention, this 

embodiment begins with a three dimension model of a scene, 700, and the first and second 
images are compared to the three dimensional model of the scene, steps 702 and 704 
respectively, to generate pose estimates. These pose estimates may be initial pose 
estimates, or may be refined as described in previous embodiments of the present 
invention. If the pose estimated are refined, it may be desirable for the matching error 
criteria to be less precise than in previous embodiments. 

[0060] Next, the first and second image are compared to one another, step 706, to 

generate constraints on the relative poses of the two images. A number of methods exist 
to generate relative pose constraints as described above with respect to Figure 6, such as 
optical flow, RANSAC, epipolar geometry calculations, and plane plus parallax. Relative 
pose constraints can also be generated due to the known motion of a single camera, or 
known spatial relationships between multiple cameras. The pose estimates are then 
updated to accommodate the relative pose constraints, step 708. While it is often 
desirable to minimize the individual image to model mismatches when the pose estimates 
are being updated, this update should result in pose estimates that fit within the relative 
pose constraints generated in step 706. 

[0061] Next, sets of relevant features from the three dimensional model, 

corresponding to the first image and the second image, are selected based on the updated 
poses, steps 710 and 712 respectively. These sets of relevant features may be selected by 
any of the previously disclosed methods. The corresponding set of relevant features is 
next projected to the estimated pose of the first image, matched to the first image and first 
image matching errors are measured, step 714. The same procedure is followed for the 
second image in step 716. 

[0062] The three dimensional model is updated using the matching errors from 

both images to improve the position estimate of objects within the model, step 718. The 
matching errors are jointly minimized with respect to position estimate for both images to 
refine the placement of known objects in the scene model. Further iterations may be used 
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to improve the model refinement, and possibly the estimated camera poses as well. These 
iterations may start by once again estimating the image poses, steps 702 and 704, or with 
the selection of sets of relevant model features, steps 710 and 712. 
[0063] The use of more than two images at a time may also increase the accuracy 

of object placement. To help overcome errors in estimating object placement when the 
estimates of camera pose are inaccurate, or vice versa, parameters may be estimated 
jointly in multiple frames, akin to bundle adjustment in structure from motion. For 
further stability, inconsistency of poses with respect to interframe alignments should also 
be penalized, e.g. uncertainties in the relative pose constraints of corresponding points in 
frame pairs may be used to weight the importance of matching errors for various images. 
[0064] This is a 3D generalization of the method disclosed in U.S. Patent number 

6,078,701, entitled "METHOD AND APPARATUS FOR PERFORMING LOCAL TO 
GLOBAL MULTI-FRAME ALIGNMENT TO CONSTRUCT MOSAIC IMAGES". 
[0065] In addition, refinement of object placement may be extended to more 

general deformations by using an additional set of parameters to describe known sizes and 
relationships of parts of objects. 

[0066] One possible use of the present invention is illustrated in Figures 8 and 9. 

This application of the present invention involves using current video from a camera 
mounted on a remote vehicle to locate the vehicle relative to objects in a three dimensional 
model. An additional application for the present invention may be to extend and refine a 
three dimensional model of an area as the area is explored by the remote vehicle possibly 
beyond the range of the scene originally covered by the model. Numerous applications in 
robotics exist for such methods. These methods may be particularly useful for the 
exploration of places in which other location techniques, such as GPS, are not practical, 
including underground, deep-sea, and interplanetary exploration. 

[0067] Figure 8 is a top plan drawing of remote vehicle 800, with mounted camera 

802, viewing the scene from Figure 1. In this exemplary sketch, the camera is turned so 
that at least a portion of each object in the scene, cube 102, star prism 104, and cylinder 
106, is visible (shown as surfaces 804). Although both the remote vehicle and the camera 
may be independently moveable, the position and angular orientation of camera 802 
relative to remote vehicle 800 are assumed to be known, or at least measurable. 
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[0068] Figure 9 is a flowchart illustrating an exemplary embodiment of the present 

invention to accurately estimate the position of a remote vehicle within a scene using a 
three dimensional model of the scene and an image of the scene. As previously described, 
the method begins with a three dimension model and an image from a camera having an 
orientation relative to the remote vehicle, 900 that can be determined. The next seven 
steps, 902, 904, 906, 908, 910, 912, and 914, involve estimating and refining the camera 
pose with respect to the three dimensional model. These steps are the same as steps 502, 
504, 506, 508, 510, 512, and 514 in the flowchart of Figure 5. 

[0069] Once the pose of the camera mounted on the vehicle has been accurately 

estimated with respect to the scene, the position and orientation of the remote vehicle 
relative to the scene in the three dimensional model may be determined, step 916. 
Because the mounted camera may be adjusted to rotate, tilt or zoom, parameters 
controlling these functions may need to be examined to determine the orientation of the 
camera relative to the remote vehicle. 

[0070] The pose of the camera may be used independently of the position and 

orientation of the vehicle to update the model. At step 918, the three dimensional model 
is updated based on data from the image and its estimated pose, step 918, similarly to step 
516 in Figure 5. Finally, the camera orientation, and possibly its position, relative to the 
remote vehicle are determined, step 920 to fix the position of the vehicle. The process 
begins again at step 902 when another image is taken. 

[0071] In addition to the large-scale model refinement of object placement 

previously discussed with regard to Figure 7, an exemplary embodiment of the present 
invention may be used for detailed refinement of a three dimensional model, including 
definition of local surface shape and texture. The true shape of the surfaces in the scene 
may differ from the planar surfaces given by the given polyhedral model, even after 
refinement of object placement. For example, between the time of model construction and 
acquisition of the current video, the existing objects may have changed, and objects may 
be added or deleted. Some scene objects, especially natural objects like trees, may be 
absent from the model, or unsatisfactorily represented, because they are hard to represent 
using simple polyhedra. This can be clearly seen for the polyhedral model of cylinder 
106 in Figure 2. 
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[0072] In another exemplary embodiment of the present invention, an untextured 

model, such as the previous mentioned polyhedral model, may be populated with pixels 
from a series of images of the scene, such as video sequences, using the estimated camera 
poses and corresponding estimated object placements. The brightness of an object in the 
scene may be approximated as being constant, independent of the viewpoint, and each 
surface pixel may be assigned a color value that is most typical of all the given images. 
[0073] As part of this embodiment polygonal surfaces of a polyhedral three- 

dimensional model may be separated into approximately equally sized portions. This may 
allow for better mapping of surface detail from a series of images onto the model, 
particularly for surfaces that are only partially visible in some of the images. Figure 10 
shows a perspective drawing of surface 200, from Figure 2, which has been separated into 
approximately equal sized portions 1000. Surface detail 1002 for one portion, which may 
be added to the polyhedral model, is also shown. By adding surface detail to a polyhedral 
model of the scene in this manner, a hybrid three-dimensional model of the scene may be 
created. 

[0074] Figure 11 is a flowchart illustrating an exemplary embodiment of the 

present invention to create such a hybrid three dimensional model of a scene using a series 
of images of the scene. The first step is to create a polyhedral model the scene, step 
1100. The polyhedral model desirably includes a plurality of polygonal surfaces, which 
are larger than a predetermined size for surface portions. Any standard technique for 
creating the model may be used. The rough shape and placement of objects in the 
polyhedral model may be refined according to the techniques of either of the flowcharts in 
Figures 5 and 7 using previous, possibly low resolution, images of the scene and/or the 
series of images to be employed for adding surface detail to the model. It is also 
important to determine the camera poses of the series of images. The poses may be 
known, or may be determined by one of the methods described above. 
[0076] Next a polygonal face is selected from the polyhedral model for 

determination of surface details, step 1102. The selection may be predetermined to sweep 
the analysis from one side of the model to its opposite side, or it may be based on a 
determination of scene areas in the images where the modeled shape appears to differ 
significantly from the existing model. The latter selection method is most useful when 
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refinement of surface details is desirably to be performed only in those areas of the model 
that deviate from the images by an amount greater than a certain threshold. 
[0077] At this point, it may be desirable to estimate and represent a refined surface 

shape as a height map associated with the selected planar surface. Given the previously 
determined camera poses, these height maps may be estimated by dense 3D estimation 
techniques from two or more observed images. The outcome of this process is a hybrid 
shape representation that augments the polyhedral model with local shape variation. 

[0078] Several relevant techniques are previously disclosed: U.S. Patent number 

5,963,664, entitled "METHOD AND SYSTEM FOR IMAGE COMBINATION USING 
A PARALLAX BASED TECHNIQUE", U.S. Patent number 5,259,040, entitled 
"METHOD FOR DETERMINING SENSOR MOTION AND SCENE STRUCTURE 
AND IMAGE PROCESSING SYSTEM THEREFOR", and U.S. Patent Application 
number 09/384118, entitled "METHOD AND APPARATUS FOR PROCESSING 
IMAGES". First, a batch of images is co-registered using the previously determined 
poses and shape model. Next, using change detection, regions are segmented out where 
the image alignment is consistently incorrect. In the detected change regions, the residual 
misalignment may be estimated, i.e. flow constrained along the epipolar lines. By 
progressing from coarse to fine image scale, such an estimation algorithm can handle a 
large amount of parallax, which may occur in areas of significant discrepancy between the 
given shape model and the actual 3D structure of the scene. Finally, the last step is to 
convert the resulting parallax magnitude to metric height. 

[0079] In the cited patents and applications, it is recommended to sum up the 

image intensity errors over all pixels, between each inspection frame and a single 
designated reference frame. However, if the batch contains frames taken from widely 
disparate viewpoints, the appearance change may be large even if well aligned. 
Therefore, it may be desirable to sum up intensity errors only between adjacent images, 
or consecutive frames, if the series of images are a video sequence. A larger subset of 
images, or frames, may also be used, but it is often desirable for this subset to be selected 
to have viewpoints within a predetermined range. 

[0080] If the batch of images used in the foregoing computation covers a 

sufficiently large range of views, the estimated shape may be very accurate; however, 
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occlusion and deocclusion areas cannot be well represented using a depth map with 
respect to one reference view. In practice, a smaller batch of images may produce a shape 
estimate good enough to align and synthesize viewpoints in the vicinity of the source data. 
It is contemplated that an alternative may be to use the parallax estimation methods to 
independently estimate and represent shape within a series of overlapping batches of 
images, each with its own reference view. Each such estimate would be stored in a 
hybrid scene representation consisting of a polyhedral model plus view-dependent local 
shape variations. 

[0081] Whether a height map of the local surface shape has been constructed or 

not, a separate texture map is next constructed for each polyhedral face in the model. The 
local height map may assist in this construction, but is not a necessary step. The first step 
of this process, step 1104 in Figure 11, is to separate the selected polygonal surface into 
portions of approximately the predetermined size for surface portions. This 
predetermined size may be as small as a single element within the model, or it may be as 
large as the entire polygonal surface. Next one of these portions is selected, step 1106. 
Z-buffering may be used to detect and discard those images which are occluded by some 
other face, leaving a subset of images which contain the selected surface portion, step 
1108. 

[0082] To determine the color value for a portion X on the surface, X is mapped 

to every image in the subset, using object placement parameters for the surface, camera 
pose parameters and, if available, the previously estimated height maps. One method, 
possibly the simplest, is to combine the color values from the pixels in the subset of 
images corresponding to X. This may be done by averaging the color values, blending 
the color values or performing another mathematical function on the color values of the 
various images in the subset. 

[0083] These methods of combining the color values ignore the possibly unequal 

quality of the images. The highest resolution, and most frontal view, of the face gives the 
most information about the surface appearance. Image resolution (e.g. in pixels/meter) 
can be assessed by the smaller singular value, /z, of the Jacobian dUi/dX|, where X| is 
measured in a 2D face-aligned coordinate system and Ui is the position in the i* image 
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corresponding to X. Thus, the image having the maximum value of \i may be selected at 
step 1110, and its color value(s) projected from pixel(s) Ui to portion X, step 1112. 
[0084] The color and brightness at corresponding points in different images may 

not be identical, due to camera gain variations and non-Lambertian surface materials. 
Abruptly switching between different source images while computing the appearance of a 
single face may cause seams to appear in the texture map. Accordingly, it may be 
desirable to use pixel values from a single image to map texture onto a given surface of 
the model, if possible. 

[0085] Alternatively, once it has been determined that all of the portions of a given 

surface have been mapped, step 1114, any artifacts caused by using multiple images to 
generate the texture maps of the portions of a single surface may be mitigated through 
multi-resolution blending of the portions, step 1116, as taught in U.S. Patent number 
6,075,905, entitled "METHOD AND APPARATUS FOR MOSAIC IMAGE 
CONSTRUCTION" . This step may also be employed when a single image is used to map 
texture onto ail of the portions of a given surface of the model. 
[0086] The foregoing method to create a surface texture map of a hybrid three 

dimensional model may be used whether the scene is initially modeled by planar faces 
alone or by a model of planar faces plus shape variations. In the generalized 
representation using view-dependent local shape, texture may be recovered for each local 
reference view. The result would be a 3D-scene model with view-dependent shape and 
texture. 

[0087] One exemplary method to synthesize a new image from a novel viewpoint 

may be to interpolate the shape and texture of two or more nearby reference views closest 
to the desired viewpoint, according to the teachings of U.S. Patent Application number 
08/917402, entitled "METHOD AND SYSTEM FOR RENDERING AND COMBINING 
IMAGES TO FORM A SYNTHESIZED VIEW OF A SCENE CONTAINING IMAGE 
INFORMATION FROM A SECOND IMAGE". 

[0088] Figure 12 is a perspective drawing of a scene, 1200, illustrating an 

exemplary video flashlights method of the present invention, which may be employed to 
synthesize an image from a novel viewpoint using a dynamic three dimensional model, 
such as those previously described with regard to the flowcharts of Figures 5, 7, and 11. 
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The exemplary scene, 1200, is being filmed by video cameras 1202, which may be in 
motion. At any given time, images from these cameras contain only a portion of the 
scene, 1204. 

[0089] It has been previously demonstrated that current video images of a semi- 

urban environment can be aligned in near real-time to site models. The textured models 
can then be rendered using graphics pipeline processors. A visual metaphor for this 
process of combining models with videos is that of video flashlights 'illuminating' 
portions 1204 of the model. The multiple camera views at a given time instant may be 
considered as video flashlights capturing the appearance of the scene from their respective 
viewpoints. The multiple appearances are coherently combined with the model to provide 
multiple users the ability to navigate through the environment while viewing the current 
appearance as derived from the video flashlights. 

[0090] Figure 13 is a flowchart illustrating an exemplary embodiment of the 

present invention to create virtual images of a scene and a dynamic three-dimensional 
model of the scene using this video flashlight method. 

[0091] This exemplary method involves two concurrent processes. Both of these 

processes start from a preexisting three dimensional model of the scene, 1300. The first 
of these processes, updating the model using the incoming video data, is exemplified in 
Figure 13 as steps 1302, 1304, 1306 and 1308. Any of the methods previously described 
above for updating a three dimensional model may be used. This dynamic updating 
process is continuous, so that the model may contain the most currently available data. 
[0092] The second process is the creation of output image sequence(s) based on the 

dynamic three-dimensional model. This process involves the selection of a virtual 
viewpoint, step 1310, and projection of the current model onto the selected viewpoint, 
step 1312. The viewpoint selection may be controlled manually, set to track a feature, or 
object, in the model, or may follow a predetermined pattern. Projection of a three 
dimensional model to form an image as seen from selected point may be performed by a 
number of well known methods, such as Z-buffering. 

[0093] Surveillance provides one possible application of this embodiment of the 

present invention. In a surveillance application using simultaneously deployed moving 
cameras, it may be difficult for a human operator to fuse and interpret real-time video 
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streams displayed on separate viewing screens. The relationship of the streams to the 
larger environment is not evident from the images, which may be unstable and narrow in 
field of view. Ideally, a visualization should portray the world as if the user were actually 
looking at the live scene, decoupled from the paths of the cameras that are collecting the 
imagery. 

[0094] An exemplary embodiment of the present invention registers all video 

frames to the model so that images from several cameras at the same time instant can be 
projected onto the model, like flashlights illuminating the scene, which may then be 
rendered for any user-selected viewpoint. In this context of the scene model, it may 
become easy to interpret the imagery and the dynamic events taking place in all streams at 
once. 

[0095] It is contemplated that the three dimensional model may be constructed to 

be devoid of moving objects and/or objects that are difficult to model onto polyhedra. 
These objects may appear in the video flashlights. In a virtual imaging system of this 
design, it may be desirable to make control of the video flashlight(s) responsive to 
movement of the virtual viewpoint(s). 

[0096] Additionally, it is contemplated that the methods previously described may 

be carried out within a general purpose computer system instructed to perform these 
functions by means of a computer-readable medium. Such computer-readable media 
include; integrated circuits, magnetic and optical storage media, as well as audio- 
frequency, radio frequency, and optical carrier waves. 

[0097] The embodiments of the present invention have been described with regard 

to polyhedral and hybrid three-dimensional models since they are appropriate for urban 
scenes dominated by planar structures, a present domain of application. Also, this format 
is well supported by software tools and graphics hardware. It is understood that those 
skilled in the art may find it advantageous to use other three dimensional models with 
these methods. Such use does not depart from the scope of the present invention. In the 
same vein, it will be understood by those skilled in the art that many modifications and 
variations may be made to the foregoing preferred embodiment without substantially 
altering the invention. 
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What is Claimed: 

1 1 . A method for accurately estimating a pose of a camera within a 

2 scene using a three dimension model of the scene, comprising the steps of: 

3 (a) generating an initial estimate of the pose; 

4 (b) selecting a set of relevant features of the three 

5 dimensional model based on the initial estimate of the pose; 

6 (c) creating a virtual projection of the set of relevant 

7 features responsive to the initial estimate of the pose; 

8 (d) matching a plurality of features of an image received 

9 from the camera to the virtual projection of the set of relevant 

10 features and measuring a plurality of matching errors; and 

11 .(e) updating the estimate of the pose to reduce the 

12 plurality of matching errors. 

1 2. A method for accurately estimating a pose of an image of a scene 

2 using a three dimension model of the scene, comprising the steps of: 

3 (a) performing a pyramid decomposition of the image to 

4 generate a set of pyramid levels of the image; 

5 (b) selecting one pyramid level from the set of pyramid 

6 levels; 

7 ( c ) generating an estimate of the pose using the selected 

8 pyramid level; 

9 (d) selecting a set of relevant features of the three 

10 dimensional model based on the estimate of the pose; 

1 1 ( e ) creating a virtual projection of the set of relevant 

12 features responsive to the estimate of the pose; 

13 (f) matching a plurality of features of the selected 

14 pyramid level to the virtual projection of the set of relevant features 

15 and measuring a plurality of matching errors; 

1 6 (g) updating the estimate of the pose to reduce the 

1 7 plurality of matching errors ; and 

18 (h) repeating to steps (e), (f), and (g) using the updated 

19 estimate of the pose until the plurality of matching errors are less 
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20 than predetermined matching criteria which is responsive to the 

21 selected pyramid level. 

1 3 . A method for refining a three dimensional model of a scene using an 

2 image of the scene taken by a camera having an unknown pose, comprising the steps of: 

3 (a) comparing the image to the three dimension model of 

4 the scene to generate an estimate of the pose; and 

5 (b) updating the three dimensional model of the scene 

6 based on data from the image and the estimate of the pose. 

1 4. A method for accurately estimating a position of remote vehicle 

2 using a three dimension model and an image from a camera having a known orientation 

3 relative to the remote vehicle, comprising the steps of: 

4 (a) comparing the image to the three dimension model of 

5 the scene to generate an estimate of the pose; 

6 (b) selecting a set of relevant features of the three 

7 dimensional model based on the estimate of the pose; 

8 (c) matching a plurality of features of the image to the 

9 set of relevant features and measuring a plurality of matching 

10 errors; 

1 1 (d) updating the estimate of the pose based on the 

12 plurality of matching errors; and 

13 (e) determining the position of the remote vehicle based 

14 on the estimate of the pose and the orientation of the camera. 

1 5. A method for refining a three dimension model of a scene 

2 containing an object using a plurality of images of the scene, each image including the 

3 object, comprising the steps of: 

4 (a) comparing a first image of the plurality of images to 

5 the three dimension model of the scene to generate an estimate of a 

r 

6 first viewpoint corresponding to the first image; 

7 (b) * comparing a second image of the plurality of images 

8 to the three dimension model of the scene to generate an estimate of 

9 a second viewpoint corresponding to the second image; 
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10 (c) selecting a first set of relevant features of the three 

1 1 dimensional model based on the first viewpoint; 

12 (d) matching a plurality of first features of the first image 

13 to the first set of relevant features and measuring a plurality of first 

14 matching errors; 

15 (e) selecting a second set of relevant features of the three 

16 dimensional model based on the second viewpoint; 

n (f) matching a plurality of second features of the second 

18 image to the second set of relevant features and measuring a 

19 plurality of second matching errors; and 

20 (g) updating a position estimate of the object within the 

21 three dimensional model of the scene based on the plurality of first 

22 matching errors and the plurality of second matching errors. 

1 6. A method for refining a three dimension model of a scene 

2 containing an object using a plurality of images of the scene, each image including the 

3 object, comprising the steps of: 

4 (a) selecting a subset of images from the plurality of 

5 images of the scene, the subset of frames containing at least two of 

6 the images; 

7 (b) determining a plurality of approximate relative 

8 viewpoints of the subset of images; 

9 (c) comparing each image in the subset of images to the 

10 three dimensional model to generate a subset of estimated viewpoints 

11 corresponding to the subset of images, the subset of estimated 

12 viewpoints constrained by the plurality of approximate relative 

13 viewpoints; 

14 (d) selecting a set of relevant features of the three 

15 dimensional model corresponding to each estimated viewpoint; 

16 (e) matching a plurality of features of the each image in 

17 the subset of images to the corresponding set of relevant features 

18 and measuring a plurality of matching errors; and 
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19 (f) updating a position estimate of the object within the 

20 three dimensional model of the scene based on the plurality of 

21 matching errors. 

1 7. A method for creating a hybrid three dimension model of a scene 

2 using a plurality of images of the scene, comprising the steps of: 

3 (a) creating a polyhedral model the scene including at 

4 least one polygonal surface; 

5 (b) determining a first set of images containing at least a 

6 section of a first polygonal surface; and 

7 (c) comparing a plurality of images selected from the 

8 first set of images to generate a local surface shape map 

9 corresponding to the first polygonal surface. 

1 8. A method for creating a textured three dimension model of a scene 

2 using a plurality of images of the scene, comprising the steps of: 

3 (a) creating a polyhedral model the scene including at 

4 least one polygonal surface; 

5 (b) identifying at least one portion of the one polygonal 

6 surface; 

7 (c) determining a first subset of images containing the at 

8 least one portion of the one polygonal surface; 

9 (d) selecting at least one selected image of the first subset 

10 of images; 

1 1 (e) projecting a corresponding section of each of the at 

12 least one selected image onto the at least one portion of the one 

13 polygonal surface of the textured three dimension model as a local 

14 color map; 

15 (f) repeating steps (c), (d), and (e) for each remaining 

16 portion of the one polygonal surface of the polyhedral model 

1 9. A method for creating a dynamic sequence of virtual images of a 

2 scene using a dynamically updated three dimension model of the scene, comprising the 

3 steps of: 
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4 (a) updating the three dimension model using a video 

5 sequence of images of the scene including the steps of; 

6 (al) determining a present viewpoint of a 

7 present image of the video sequence of images; 

8 (a2) determining a relevant portion of the three 

9 dimensional model corresponding to the present image of the 

10 video sequence of images; 

1 1 (a3) updating the relevant portion of the three 

12 dimensional model by projecting the present image onto the 

13 relevant portion of the three dimension model; 

14 (b) selecting a first virtual viewpoint of a first virtual 

15 image of the dynamic sequence of virtual images; 

16 (c) creating the first virtual image by projecting the 

17 dynamic three dimensional model onto the first virtual viewpoint; 

18 and 

19 (d) repeating steps (b) and (c) for each remaining virtual 

20 image of the dynamic sequence of virtual images. 

1 10. A computer readable medium adapted to instruct a general purpose 

2 computer to update a three dimensional model of a scene using the three dimensional 

3 model of the scene, an image received from a camera having an unknown pose, the 

4 method comprising the steps of: 

5 (a) generating an estimate of the pose; 

6 (b) selecting a set of relevant features of the three 

7 dimensional model based on the estimate of the pose; 

8 (c) creating a virtual projection of the set of relevant 

9 features responsive to the estimate of the pose; 

10 (d) matching a plurality of features of an image received 

1 1 from the camera to the virtual projection of the set of relevant 

12 features and measuring a plurality of matching errors; 

13 (e) updating the estimate of the pose to reduce the 

14 plurality of matching errors; and 
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15 (f) updating the three dimensional model of the scene 

16 based on data from the image and the estimate of the pose. 

1 1 1 . An automatic three-dimensional model updating apparatus for 

2 accurately estimating a point of view of an image of a scene, relative to a three- 

3 dimensional model of the scene, and updating the three-dimensional model comprising: 

4 (a) estimating means for providing an estimate of the 

5 point of view of the image; 

6 (b) relevant feature selecting means for selecting a set of 

7 relevant features of the three dimensional model based on the 

8 estimate of the point of view; 

9 (c) virtual projection means for creating a virtual 

10 projection of the set of relevant features responsive to the estimate 

11 of the point of view; 

12 (d) matching means for matching a plurality of features 

13 of the image to the virtual projection of the set of relevant features; 

14 (e) measurement means for measuring a plurality of 

15 matching errors; 

16 (f) point of view refinement means for updating the 

17 estimate of the point of view to reduce the plurality of matching 

18 errors; and 

* 19 (g) model refinement means, responsive to the estimated 

20 point of view and to the image, for updating the three-dimensional 

21 model. 
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